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achieved by only employing high fidelity modes (i.e., high bit rate, 
broadly applicable to different types of speech) during portions of the 
speech where this fidelity is required for acceptable output. Lower 
bit rate modes are used during portions of speech where these modes 
produce acceptable output. Input speech signal is classified into active 
and inactive regions. Active regions are further classified into voiced, 
unvoiced, and transient regions. Various coding modes are applied to 
active speech, depending upon the required level of fidelity. Coding 
modes may be utilized according to the strengths and weaknesses of 
each particular mode. The apparatus dynamically switches between 
these modes as the properties of the speech signal vary with time. And 
where appropriate, regions of speech are modeled as pseudo— random 
noise, resulting in a significantly lower bit rate. This coding is used in 
a dynamic fashion whenever unvoiced speech or background noise is 
detected. 
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VARIABLE RATE SPEECH CODING 
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BACKGROUND OF THE INVENTION 

I. Field of the Invention 

5 The present invention relates to the coding of speech signals. Specifically, the 

present invention relates to classifying speech signals and employing one of a plurality of 
coding modes based on the classification. 

EL Description of the Related Art 

Many communication systems today transmit voice as a digital signal, particularly 

10 long distance and digital radio telephone applications. The performance of these systems 
depends, in part, on accurately representing the voice signal with a minimum number of 
bits. Transmitting speech simply by sampling and digitizing requires a data rate on the 
order of 64 kilobits per second (kbps) to achieve the speech quality of a conventional 
analog telephone. However, coding techniques are available that significantly reduce the 

15 data rate required for satisfactory speech reproduction. 

The term "vocoder" typically refers to devices that compress voiced speech by 
extracting parameters based on a model of human speech generation. Vocoders include an 
encoder and a decoder. The encoder analyzes the incoming speech and extracts the relevant 
parameters. The decoder synthesizes the speech using the parameters that it receives from 

20 the encoder via a transmission channel. The speech signal is often divided into frames of 
data and block processed by the vocoder. 

Vocoders built around linear-prediction-based time domain coding schemes far 
exceed in number all other types of coders. These techniques extract correlated elements 
from the speech signal and encode only the uncorrected elements. The basic linear 

25 predictive filter predicts the current sample as a linear combination of past samples. An 
example of a coding algorithm of this particular class is described in the paper "A 4.8 kbps 
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Code Excited Linear Predictive Coder," by Thomas E. Tremain et al., Proceedings of the 
Mobile Satellite Conference, 1988. 

These coding schemes compress the digitized speech signal into a low bit rate signal 
by removing all of the natural redundancies (i.e., correlated elements) inherent in speech. 

5 Speech typically exhibits short term redundancies resulting from the mechanical action of 
the lips and tongue, and long term redundancies resulting from the vibration of the vocal 
cords. Linear predictive schemes model these operations as filters, remove the 
redundancies, and then model the resulting residual signal as white gaussian noise. Linear 
predictive coders therefore achieve a reduced bit rate by transmitting filter coefficients and 

10 quantized noise rather than a full bandwidth speech signal. 

However, even these reduced bit rates often exceed the available bandwidth where 
the speech signal must either propagate a long distance (e.g., ground to satellite) or coexist 
with many other signals in a crowded channel. A need therefore exists for an improved 
coding scheme which achieves a lower bit rate than linear predictive schemes. 

1 5 SUMMARY OF THE INVENTION 

The present invention is a novel and improved method and apparatus for the 
variable rate coding of a speech signal. The present invention classifies the input speech 
signal and selects an appropriate coding mode based on this classification. For each 
classification, the present invention selects the coding mode that achieves the lowest bit rate 

20 with an acceptable quality of speech reproduction. The present invention achieves low 
average bit rates by only employing high fidelity modes (i.e., high bit rate, broadly 
applicable to different types of speech) during portions of the speech where this fidelity is 
required for acceptable output. The present invention switches to lower bit rate modes 
during portions of speech where these modes produce acceptable output. 

25 An advantage of the present invention is that speech is coded at a low bit rate. Low 

bit rates translate into higher capacity, greater range, and lower power requirements. 

A feature of the present invention is that the input speech signal is classified into 
active and inactive regions. Active regions are further classified into voiced, unvoiced, and 
transient regions. The present invention therefore can apply various coding modes to 
30 different types of active speech, depending upon the required level of fidelity. 
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Another feature of the present invention is that coding modes may be utilized 
according to the strengths and weaknesses of each particular mode. The present invention 
dynamically switches between these modes as properties of the speech signal vary with 
time. 

5 A further feature of the present invention is that, where appropriate, regions of 

speech are modeled as pseudo-random noise, resulting in a significantly lower bit rate. The 
present invention uses this coding in a dynamic fashion whenever unvoiced speech or 
background noise is detected. 

The features, objects, and advantages of the present invention will become more 
10 apparent from the detailed description set forth below when taken in conjunction with the 
drawings in which like reference numbers indicate identical or functionally similar 
elements. Additionally, the left-most digit of a reference number identifies the drawing in 
which the reference number first appears.. 



BRIEF DESCRIPTION OF THE DRAWINGS 



15 FIG. 1 is a diagram illustrating a signal transmission environment; 

FIG. 2 is a diagram illustrating encoder 102 and decoder 104 in greater detail; 
FIG. 3 is a flowchart illustrating variable rate speech coding according to the present 
invention; 

FIG. 4A is a diagram illustrating a frame of voiced speech split into subframes; 
20 FIG. 4B is a diagram illustrating a frame of unvoiced speech split into subframes; 

FIG. 4C is a diagram illustrating a frame of transient speech split into subframes; 
FIG. 5 is a flowchart that describes the calculation of initial parameters; 
FIG. 6 is a flowchart describing the classification of speech as either active or 
inactive; 

25 FIG. 7A depicts a CELP encoder; 

FIG. 7B depicts a CELP decoder; 
FIG. 8 depicts a pitch filter module; 
FIG. 9A depicts a PPP encoder; 
FIG. 9B depicts a PPP decoder; 



PCT/US99/30587 

WO 00/38179 

4 

FIG. 10 is a flowchart depicting the steps of PPP coding, including encoding and 
decoding; 

FIG. 11 is a flowchart describing the extraction of a prototype residual period; 

FIG. 12 depicts a prototype residual period extracted from the current frame of a 
5 residual signal, and the prototype residual period from the previous frame; 

FIG. 13 is a flowchart depicting the calculation of rotational parameters; 

JIG. 14 is a flowchart depicting the operation of the encoding codebook; 

FIG. 1 5 A depicts a first filter update module embodiment; 

FIG. 15B depicts a first period interpolator module embodiment; 
10 FIG. 1 6A depicts a second filter update module embodiment; 

FIG. 1 6B depicts a second period interpolator module embodiment; 

FIG. 17 is a flowchart describing the operation of the first filter update module 

embodiment; 

FIG. 18 is a flowchart describing the operation of the second filter update module 

15 embodiment; 

FIG. 19 is aflowchart describe 

periods; 

FIG. 20 is a flowchart describing the reconstruction of a speech signal based on 
prototype residual periods according to a first embodiment; 
20 FIG. 21 is a flowchart describing the reconstruction of a speech signal based on 

prototype residual periods according to a second embodiment; 
FIG. 22A depicts a NELP encoder; 
FIG. 22B depicts a NELP decoder; and 
FIG. 23 is a flowchart describing NELP coding. 
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DETAILED DESCRIPTION OF THE PREFERRED 
EMBODIMENTS 

I. Overview of the Environment 

II. Overview of the Invention 

5 III. Initial Parameter Determination 

A. Calculation of LPC Coefficients 

B. LSI Calculation 

C. NACF Calculation 

D. Pitch Track and Lag Calculation 

10 E Calculation of Band Energy and Zero Crossing Rate 

F. Calculation of the Formant Residual 

IV. Active/Inactive Speech Classification 

A. Hangover Frames 

V. Classification of Active Speech Frames 
15 VI. Encoder/Decoder Mode Selection 

VII. Code Excited Linear Prediction (CELP) Coding Mode 

A. Pitch Encoding Module 

B. Encoding codebook 

C. CELP Decoder 

20 D. Filter Update Module 

VIII. Prototype Pitch Period (PPP) Coding Mode 

A. Extraction Module 

B. Rotational Correlator 

C. Encoding Codebook 
25 D. Filter Update Module 

E. PPP Decoder 

F. Period Interpolator 

IX. Noise Excited Linear Prediction (NELP) Coding Mode 

X. Conclusion 
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I. Overview of the Environment 

The present invention is directed toward novel and improved methods and 
apparatuses for variable rate speech coding. FIG. 1 depicts a signal transmission 
environment 1 00 including an encoder 102, a decoder 104, and a transmission medium 106. 
5 Encoder 102 encodes a speech signal s(n), forming encoded speech signal s,Jn), for 
transmission across transmission medium 106 to decoder 104. Decoder 104 decodes s.Jn), 

thereby generating synthesized speech signal s(n) 

The term "coding" as used herein refers generally to methods encompassing both 
encoding and decoding. Generally, coding methods and apparatuses seek to minimize the 
10 number of bits transmitted via transmission medium 106 {i.e., minimize the bandwidth of 
s t Jn)) while maintaining acceptable speech reproduction (i.e., s{ri) ~s(n)). The 

composition of the encoded speech signal will vary according to the particular speech 
coding method. Various encoders 102, decoders 104, and the coding methods according 
to which they operate are described below. 
15 The components of encoder 102 and decoder 104 described below may be 

implemented as electronic hardware, as computer software, or combinations of both. These 
components are described below in terms of their functionality. Whether the functionality 
is implemented as hardware or software will depend upon the particular application and 
design constraints imposed on the overall system. Skilled artisans will recognize the 
20 interchangeability of hardware and software under these circumstances, and how best to 
implement the described functionality for each particular application. 

Those skilled in the art will recognize that transmission medium 1 06 can represent 
many different transmission media, including, but not limited to, a land-based 
communication line, a link between a base station and a satellite, wireless communication 
25 between a cellular telephone and a base station, or between a cellular telephone and a 
satellite. 

Those skilled in the art will also recognize that often each party to a communication 
transmits as well as receives. Each party would therefore require an encoder 102 and a 
decoder 104. However, signal tranmission environment 100 will be described below as 
30 including encoder 102 at one end of transmission medium 106 and decoder 104 at the other. 
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Skilled anisanswillreadUyrecognizehowto extend these ideas to two-way communication. 

For purposes of this description, assume that s(n) is a digital speech signal obtained 
during a typical conversation including different vocal sounds and periods of silence. The 
speech signal s(n) is preferably partitioned into frames, and each frame is further partitioned 
5 into subframes (preferably 4). These arbitrarily chosen frame/subframe boundaries are 
commonly used where some block processing is performed, as is the case here. Operations 
described as being performed on frames might also be performed on subframes-in this 
sense, frame and subframe are used interchangeably herein. However, s(n) need not be 
partitioned into frames/subframes at all if continuous processing rather than block 

10 processing is implemented. Skilled artisans will readily recognize how the block 
techniques described below might be extended to continuous processing. 

In a preferred embodiment, s(n) is digitally sampled at 8 kHz. Each frame 
preferably contains 20ms of data, or 160 samples at the preferred 8 kHz rate. Each 
subframe therefore contains 40 samples of data. It is important to note that many of the 

15 equations presented below assume these values. However, those skilled in the an will 
recognize that while these parameters are appropriate for speech coding, they are merely 
exemplary and other suitable alternative parameters could be used. 
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n. Overview of the Invention 

The methods and apparatuses of the present invention involve coding the speech 
signal s(n). FIG. 2 depicts encoder 102 and decoder 104 in greater detail. According to the 
present invention, encoder 102 includes an initial parameter calculation module 202, a 
5 classification module 208, and one or more encoder modes 204. Decoder 104 includes one 
or more decoder modes 206. The number of decoder modes, N„, in general equals the 
number of encoder modes, N e . As would be apparent to one skilled in the art, encoder 
mode 1 communicates with decoder mode 1, and so on. As shown, the encoded speech 
signal, s.Jn), is transmitted via transmission medium 106. 
10 In a preferred embodiment, encoder 102 dynamically switches between multiple 

encoder modes from frame to frame, depending on which mode is most appropriate given 
the properties of s(n) for the current frame. Decoder 104 also dynamically switches 
between the corresponding decoder modes from frame to frame. A particular mode is 
chosen for each frame to achieve the lowest bit rate available while maintaining acceptable 
15 signal reproduction at the decoder. This process is referred to as variable rate speech 
coding, because the bit rate of the coder changes over time (as properties of the signal 
change). 

FIG. 3 is a flowchart 300 that describes variable rate speech coding according to the 
present invention. In step 302, initial parameter calculation module 202 calculates various 
20 parametersbased on the current frame of data. In apreferred embodiment, these parameters 
include one or more of the following: linear predictive coding (LPC) filter coefficients, line 
spectrum information (LSI) coefficients, the normalized autocorrelation functions (NACFs), 
the open loop lag, band energies, the zero crossing rate, and the formant residual signal. 
In step 304, classification module 208 classifies the current frame as containing 
25 either "active" or "inactive" speech. As described above, s(n) is assumed to include both 
periods of speech and periods of silence, common to an ordinary conversation. Active 
speech includes spoken words, whereas inactive speech includes everything else, e.g., 
background noise, silence, pauses. The methods used to classify speech as active/inactive 
according to the present invention are described in detail below. 
30 As shown in FIG. 3, step 306 considers whether the current frame was classified as 

active or inactive in step 304. If active, control flow proceeds to step 308. If inactive, 
control flow proceeds to step 3 10. 
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Those frames which are dassified as active are further classified in step 30S as 
e.t»er vo.ced, unvoice, „ r t^m ^ ^ skj|Ied fa ^ ^ ^ 

human speech can be classified in many different „a y s. Two convention., Cassations 
ofspeecb are voiced and unvoiced sounds According ,o *e presen, invenUon, a„ speech 
5 which is not voiced or unvoiced is dassified as transient speech 

HG. 4A depicts an example portion of sfiO including voiced speech 402 Voiced 
sounds are produced by fordng air tough the giorts with the tension of the vocal cords 
adjusted so that they vibrate in a relaxed osciliafon, thereby producing q „asi-periodic 
pu.se.ofairwhichexcheutevocalu.c. One common property measured in voiced speech 
1 0 is the pitch period, as shown in FIG. 4 A. 

HG. 4B deptcts an example portion of s(n) including unvoiced speech 404 
U„vo,ced sounds are generated by forming a enaction a, some point in the vocal tract 
(usually toward the mouth end), and forcing air tough the constriction a, a high enough 
velocity ,„ produce turbulence. The resulting unvoiced speech signal resembles colored 

15 noise. 

FIG. 4C depicts an example portion of s(n) including transient speech 406 (/ e 
speech which is neither voiced nor unvoiced). The example transient speech 406 shown 
m FIG. 4C might represent s(n) transitioning between unvoiced speech and voiced speech 
Skilled artisans will recognize that many different classifications of speech could be 
20 employed according to the techniques described herein to achieve comparable results 

In step 3 10, an encoder/decoder mode is selected based on the frame classification 
made in steps 306 and 308. The various encoder/decoder modes are connected in parallel 
as shown in FIG. 2. One or more of these modes can be operational at any given time' 
However, as described in detail below, only one mode preferably operates at any given 
25 time, and ,s selected according to the classification of the current frame. 

Several encoder/decoder modes are described in the following sections The 
different encoder/decoder modes operate according to different coding schemes. Certain 
modes are more effective at coding portions of the speech signal s(n) exhibiting certain 
properties. 

In a preferred embodiment, a "Code Excited Linear Predictive" (CELP) mode is 
chosen to code frames classified as transient speech. The CELP mode excites a linear 
predictive vocal tract model with a quantized version of the linear prediction residua. 
s lg nal. Of all the encoder/decoder modes described herein, CELP generally produces the ' 



30 
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most accurate speech reproduction but requires the highest bit rate. In one embodiment, the 
CELP mode performs encoding at 8500 bits per second. 

A "Prototype Pitch Period" (PPP) mode is preferably chosen to code frames 
classified as voiced speech. Voiced speech contains slowly time varying periodic 
5 components which are exploited by the PPP mode. The PPP mode codes only a subset of 
the pitch periods within each frame. The remaining periods of the speech signal are 
reconstructed by interpolating between these prototype periods. By exploiting the 
periodicity of voiced speech, PPP is able to achieve a lower bit rate than CELP and still 
reproduce the speech signal in a perceptually accurate manner. In one embodiment, the 
10 PPP mode performs encoding at 3900 bits per second. 

A "Noise Excited Linear Predictive" (NELP) mode is chosen to code frames 
classified as unvoiced speech. NELP uses a filtered pseudo-random noise signal to model 
unvoiced speech. NELP uses the simplest model for the coded speech, and therefore 
achieves the lowest bit rate. In one embodiment, the NELP mode performs encoding at 
15 1500 bits per second. 

The same coding technique can frequently be operated at different bit rates, with 
varying levels of performance. The different encoder/decoder modes in FIG. 2 can 
therefore represent different coding techniques, or the same coding technique operating at 
different bit rates, or combinations of the above. Skilled artisans will recognize that 
20 increasing the number of encoder/decoder modes will allow greater flexibility when 
choosing a mode, which can result in a lower average bit rate, but will increase complexity 
within the overall system. The particular combination used in any given system will be 
dictated by the available system resources and the specific signal environment. 

In step 3 12, the selected encoder mode 204 encodes the current frame and preferably 
25 packs the encoded data into data packets for transmission. And in step 314, the 
corresponding decoder mode 206 unpacks the data packets, decodes the received data and 
reconstructs the speech signal. These operations are described in detail below with respect 
to the appropriate encoder/decoder modes. 
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HI. Initial Parameter Determination 

FIG. 5 is a flowchart describing step 302 in greater detail. Various initial 
parameters are calculated according to the present invention. The parameters preferably 
include, e.g., LPC coefficients, line spectrum information (LSI) coefficients, normalized 
5 autocorrelation functions (NACFs), open loop lag, band energies, zero crossing rate, and 
the formant residual signal. These parameters are used in various ways within the overall 
system, as described below. 

In a preferred embodiment, initial parameter calculation module 202 uses a "look 
ahead" of 160 + 40 samples. This serves several purposes. First, the 160 sample look 

10 ahead allows a pitch frequency track to be computed using information in the next frame, 
which significantly improves the robustness of the voice coding and the pitch period 
estimation techniques, described below. Second, the 160 sample look ahead also allows 
the LPC coefficients, the frame energy, and the voice activity to be computed for one frame 
in the future. This allows for efficient, multi-frame quantization of the frame energy and 

15 LPC coefficients. Third, the additional 40 sample look ahead is for calculation of the LPC 
coefficients on Hamming windowed speech as described below. Thus the number of 
samples buffered before processing the current frame is 1 60 + 160 + 40 which includes the 
current frame and the 160 + 40 sample look ahead. 

A. Calculation of LPC Coefficients 

20 The present invention utilizes an LPC prediction error filter to remove the short 

term redundancies in the speech signal. The transfer function for the LPC filter is: 

10 

The present invention preferably implements a tenth-order filter, as shown in the previous 
equation. An LPC synthesis filter in the decoder reinserts the redundancies, and is given 
25 by the inverse of A(z): 

1 1 
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In step 502, the LPC coefficients, a„ are computed from s(n) as follows. The LPC 
parameters are preferably computed for the next frame during the encoding procedure for 
the current frame. 

A Hamming window is applied to the current frame centered between the 1 1 9 th and 
5 120 th samples (assuming the preferred 160 sample frame with a "look ahead"). The 
windowed speech signal, sjn) is given by : 

j w (w)= s{n + 40)^0.5 + 0.46* co^ " ~ 8 q 9 ' 5 ) ) > 0< «< 160 

The offset of 40 samples results in the window of speech being centered between the 1 19 th 
and 120 th sample of the preferred 160 sample frame of speech. 
10 Eleven autocorrelation values are preferably computed as 

W='S ^{m)s w (m+k), 0<k<\0 

rr.-Q 

The autocorrelation values are windowed to reduce the probability of missing roots of line 
spectral pairs (LSPs) obtained from the LPC coefficients, as given by: 

R{k)=h(k)R(k\ 0<k<\0 
15 resulting in a slight bandwidth expansion, e.g., 25 Hz. The values are preferably taken 
from the center of a 255 point Hamming window. 

The LPC coefficients are then obtained from the windowed autocorrelation values 
using Durbin's recursion. Durbin's recursion, a well known efficient computational 
method, is discussed in the tpvt Di pita) Processing of Speech Signals by Rabiner & Schafer. 

20 B. LSI Calculation 

In step 504, the LPC coefficients are transformed into line spectrum information 
(LSI) coefficients for quantization and interpolation. The LSI coefficients are computed 
according to the present invention in the following manner. 
As before, A(z) is given by 

25 A(z) = 1 - a x z' x # io z ~ 10 » 

where a, are the LPC coefficients, and 1 £ / £ 10. 
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PJz) and Q A (z) are defined as the following 



where 



A= -a,-a M _„ 1 < / < 10 
<7, = -a,. + a,,_,., l£/< 10 



and 



Po = 1 /?„ = 1 
<7o = 1 <7 n = - 1 

The line spectral cosines (LSCs) are the ten roots in -1 .0 < x < 1 .0 of the following 
two functions: 

p '(*)= P'o, cos (Scos' 1 (x))± p'j (4cos' J (xJJ+ p' 4 + p' 5 /2 
Q'(x)= q' 0 cos(5 cos~ J (xJJ+ q> ; (4 cos' 1 (x))+ —+ q' 4 x+ q' 5 /2 

10 where 

/>'/= A -/>'../ Is/i5 
9' l = g, + q' i . l lsi*S 

15 The LSI coefficients are then calculated as: 

Isi - l °- 5 ^ 1 ~ / jc ' /JC ' * 0 

' li.o-o.5vrr^" isc,<o 

The LSCs can be obtained back from the LSI coefficients according to: 



Isc, = 



1.0 -4Isif Isi, < 0.5 

(4-4/ji, 2 )-1.0 /s/ f >0.5 
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The stability of the LPC filter guarantees that the roots of the two functions 
alternate, i.e., the smallest root, Iscj, is the smallest root ofP'fx), the next smallest root, lsc 2> 
is the smallest root of Q '(x), etc. Thus, lsc h lsc Jy lsc s , lsc 7 , and lsc 9 are the roots of P '(x) y 
and lsc 2) lsc 4 , isc 6 , lsc s , and lsc ]0 are the roots of Q'(x). 
5 Those skilled in the art will recognize that it is preferable to employ some method 

for computing the sensitivity of the LSI coefficients to quantization. "Sensitivity 
weightings" can be used in the quantization process to appropriately weight the quantization 
error in each LSI. 

The LSI coefficients are quantized using a multistage vector quantizer (VQ). The 
10 number of stages preferably depends on the particular bit rate and codebooks employed. 
The codebooks are chosen based on whether or not the current frame is voiced. 

The vector quantization minimizes a weighted-mean-squared error (WMSE) which 
is defined as 

p-\ 

E(x,y)= X w i( x i-y>) 2 

i=0 

15 where 3c is the vector to be quantized, w the weight associated with it, and y is the 

codevector. In a preferred embodiment, w are sensitivity weightings and P — 10. 

The LSI vector is reconstructed from the LSI codes obtained by way of quantization 

- AT 

as qlsi = ^ CBi coda where CBi is the /'* stage VQ codebook for either voiced or 
1=1 

unvoiced frames (this is based on the code indicating the choice of the codebook) and code i 

20 is the LSI code for the i tk stage. 

Before the LSI coefficients are transformed to LPC coefficients, a stability check 
is performed to ensure that the resulting LPC filters have not been made unstable due to 
quantization noise or channel errors injecting noise into the LSI coefficients. Stability is 
guaranteed if the LSI coefficients remain ordered. 

25 In calculating the original LPC coefficients, a speech window centered between the 

1 1 9 th and 1 20 th sample of the frame was used. The LPC coefficients for other points in the 
frame are approximated by interpolating between the previous frame's LSCs and the current 
frame's LSCs. The resulting interpolated LSCs are then converted back into LPC 
coefficients. The exact interpolation used for each subframe is given by: 
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ilscj=(\ - a,)lscprevj + ajsccun-j, \ sy s 10 

where a t are the interpolation factors 0.375, 0.625, 0.875, 1 .000 for the four subframes of 
40 samples each and Use are the interpolated LSCs. P A (z) and Q A (z ) are computed by 
the interpolated LSCs as 



P A {z) = (1+ 2-'>n 1- 2iisc 2j ._ } z- 1 + z- 2 
aW a (l-2-')Il \-2ilsc 2J z-^z- 2 



J'l 

5 The interpolated LPC coefficients for all four subframes are computed as coefficients 

A(z) = *a< z 

Thus, 



of 



A A 

Pi + 9i 
2 

A A 



1 < /' <, 5 



6^/<10 



C. NACF Calculation 



In step 506, the normalized autocorrelation functions (NACFs) are calculated 
•according to the current invention. 

10 

as 



The formant residual for the next frame is computed over four 40 sample subframes 



r( n) = s(n) - £ a t s(n - i) 



1=1 
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where a t is the i th interpolated LPC coefficient of the corresponding subframe, where the 
interpolation is done between the current frame's unquantized LSCs and the next frame's 
LSCs. The next frame's energy is also computed as 



E„ = 0.5 log, 



( 159 

Z r 2 (n) 



;=0 



160 



V 



5 The residual calculated above is low pass filtered and decimated, preferably using 

a zero phase FIR filter of length 15, the coefficients of which df h -1 <> i < 7, are {0.0800, 
0.1256, 0.2532, 0.4376, 0 : 6424, 0.8268, 0.9544, 1.000, 0.9544, 0.8268, 0.6424, 0.4376, 
0.2532, 0.1256, 0.0800}. The low pass filtered, decimated residual is computed as 

7 

r A n ) = X. d fi r ( Fn + / J, 0 < n < 1 60 / F 



10 where F - 2 is the decimation factor, and r(Fn + /), -7 < Fn + i ' £ 6 are obtained from the 
last 14 values of the current frame's residual based on unquantized LPC coefficients. As 
mentioned above, these LPC coefficients are computed and stored during the previous 
frame. 

The NACFs for two subframes (40 samples decimated) of the next frame are 
15 calculated as follows: 

39 

Exx k = X ^(40* + i)r d (40*+ i\ k = 0,1 

r-0 

39 



&ykj = Z r d {AQk + i)r d (40£+ /- j), 



1=0 



39 



12/2< y< 128/2,*= 0,1 



E m.j = Z r * ( 40 * + ' - J) r d ( 40 * + < - A 



i=0 



n_corr kJ _ u!2 = 



12/2< >< 128/2,^=0,1 

12/2< y<128/2,£ = 0,l 
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For r/n) with negative n, the current frame's low-pass filtered and decimated 
residual (stored during the previous frame) is used. The NACFs for the current subframe 
c_corrwere also computed and stored during the previous frame. 

D. Pitch Track and Lag Calculation 

5 In step 508, the pitch track and pitch lag are computed according to the present 

invention. The pitch lag is preferably calculated using a Viterbi-like search with a 
backward track as follows. 

Rl, = n_corr QJ + ™zx{n_corr UJ+FAN J, 
0 < i < 1 16/2,0 <: j < FAN i X 



10 



R2 t = c_corr,. + max{R\ J+FAN J, 

0< i< 1 16/2,0 < j < FAN ia 

RM 2i = R2 t + max {c_corr 0/+FAN o ), 

0 < / < 1 16 /2,0 < j < FAN i X 



where FAN fJ is the 2 * 58 matrix, {{0,2}, {0,3}, {2,2}, {2,3}, {2,4}, {3,4}, {4,4}, {5,4}, 
{5,5}, {6,5}, (7,5}, {8,6}, {9,6}, {10,6}, {11,6}, {11,7}, {12,7}, {13,7}, {14,8}, {15,8}, 
{16,8}, {16,9}, {17,9}, {18,9}, {19,9}, {20,10}, {21,10}, {22,10}, {22,11}, {23,11}, 
15 {24,1 1}, {25,12}, {26,12}, {27,12}, {28.12}, {28,13}, {29,13}, {30,13}, {3 1,14}, {32,14}, 
{33,14}, {33,15}, {34,15}, {35,15}, {36,15}, {37,16}, {38,16}, {39,16}, {39,17}, {40,17}, 
{41,16}, {42,16}, {43,15}, {44,14}, {45,13}, {45,13}, {46,12}, {47,11}}. The vector 
RMy is interpolated to get values for as 

. WJ)F , l<.i< 112/2 

y=o 

RM X = ( RM Q + RM 2 )/2 
RM 2 , iM = (RM 2 ^ + RM 2 , 57 )/2 
RM 2t57 ^ = RM 2 . 57 
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where cf } is the interpolation filter whose coefficients are {-0.0625, 0.5625, 0.5625, 
-0.0625}. The lag L c is then chosen such that ^ = max{ R j } , 4 <> i < 1 16 and the 

current frame's NACF is set equal to / 4 . Lag multiples are then removed by 

searching for the lag corresponding to the maximum correlation greater than 0.9 R r 
5 amidst: 



10 



^ax^/uj- 14,16} •*' jR LwJ-io for all 1 z M 4 [_L C /16j 



E. Calculation of Band Energy and Zero Crossing Rate 

In step 510, energies in the 0-2kHz band and 2kHz-4kHz band are computed 
according to the present invention as 

159 
i=0 



159 



where, 



£ * = Z .s 2 H (n) 



S L (z)=S(z) ° 
S H (z)=S(z)- ^ 



s ( r )> s i(-) and Sffe) being the z-transforms of the input speech signal s(n), low-pass signal 
s L (n) and high-pass signal sjn), respectively, £/={0.0003, 0.0048, 0.0333, 0. 1443, 0.4329, 

15 0.9524, 1 .5873, 2.0409, 2.0409, 1.5873, 0.9524, 0.4329, 0.1443, 0.0333, 0.0048, 0.0003}, 
a/={1.0, 0.9155, 2.4074, 1 .651 1, 2.0597, 1.0584, 0.7976, 0.3020, 0. 1465, 0.0394, 0.0122, 
0.0021, 0.0004, 0.0, 0.0, 0.0}, bh={Q.00U, -0.0189, 0.1324, -0.5737, 1.7212, -3.7867, 
6.3 112, -8. 1 144, 8.1 144, -6.3 1 12, 3 .7867,-1.7212, 0.5737, -0. 1 324, 0.01 89, -0.0013} and 
ah={l.0, -2.8818, 5.7550, -7.7730, 8.2419, -6.8372, 4.6171, -2.5257, 1.1296, -0.4084, 

20 0.1 183, -0.0268, 0.0046, -0.0006, 0.0, 0.0}. 
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159 

The speech signal energy itself is E = £ s 2 (n) . The 



zero crossing rate ZCR is 



computed as 



\£(s(n)s(n + 1) < 0)ZCR = ZC* + 1, 



0 *n< 159 



Calculation of the Formant Residual 



step 512, the formant residual for the current frame is computed 



over four 



subframes as 



curr 



10 A 



where d, is the /'* LPC coefficient of the corresponding subframe. 

IV. Active/Inactive Speech Classification 

Referring back to FIG. 3, in step 304, the current frame is classified as either active 
1 0 speech (e.g. , spoken words) or inactive speech (e.g. , background noise, silence). FIG. 6 is 
a flowchart 600 that depicts step 304 in greater detail In a preferred embodiment, a two 
energy band based thresholding scheme is used to determine if active speech is present. 
The lower band (band 0) spans frequencies from 0.1-2.0 kHz and the upper band (band 1) 
from 2.0-4.0 kHz. Voice activity detection is preferably determined for the next frame 
1 5 during the encoding procedure for the current frame, in the following manner. 

In step 602, the band energies EbfiJ for bands / = 0, 1 are computed. The 
autocorrelation sequence, as described above in Section III. A., is extended to 19 using the 
following recursive equation; 



20 Using this equation, R(U) is computed from R(l) to R(10) y R(12) is computed from R(2) 
to R(Jl) t and so on. The band energies are then computed from the extended 
autocorrelation sequence using the following equation: 



10 
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£*(')= log 2 (/?(0)/2 fc (P)(0)+2I R(k)R h (0(k)\ , i = 0,1 

where is the extended autocorrelation sequence for the current frame and R h (i)(k) is the 
band filter autocorrelation sequence for band / given in Table 1 . 

Table 1: Filter Autocorrelation Sequences for Band Energy Calculations 



k 


r a(°)(£) band 0 


R h (l(k) band 1 


0 


4.230889E-01 


4.042770E-01 


1 


2.693014E-01 


-2.503076E-01 


2 


-1.124000E-02 


-3.059308E-02 


3 


-1.301279E-01 


1.497124E-01 


4 


-5.949044E-02 


-7.9059S4E-02 


5 


1.494007E-02 


4.371288E-03 


6 


-2.087666E-03 


-2.088545E-02 


7 


-3.823536E-02 


5.622753E-02 


8 


-2.748034E-02 


-4.420598E-02 


9 


3.015699E-04 


1.443 167E-02 


10 


3.722060E-03 


-8.462525E-03 


11 


-6.416949E-03 


1.627144E-02 


12 


-6.551736E-03 


-1.476080E-02 


13 


5.493820E-04 


6.1 8704 1E-03 


14 


2.934550E-03 


-1.898632E-03 


15 


8.041829E-04 


2.053577E-03 


16 


-2.857628E-04 


-1.860064E-03 


17 


2.585250E-04 


7.72961 8E-04 


18 


4.816371E-04 


-2.297862E-04 


19 


1. 69273 8E-04 


2.107964E-04 



In step 604, the band energy estimates are smoothed. The smoothed band energy 
estimates, E^(i), are updated for each frame using the following equation. 

E„(i) = 0.6E„(i) + 0.4^(0, i = 0,1 

In step 606, signal energy and noise energy estimates are updated. The signal 
30 energy estimates, E/i), are preferably updated using the following equation: 

£//)=max(£, m (/),£, (OX ' = 0,1 
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The noise energy estimates, E H (i), are preferably updated using the following 
equation: 

£ n (0=min(£, m (/),£„(/)), ,= 0,1 

In step 608, the long terra signal-to-noise ratios for the two bands, SNR(i), are 
5 computed as 

SNR«)= EXi)-E n (0, i=0,l 

In step 610, these SNR values are preferably divided into eight regions Reg 5NR (i) 
denned as 



0 0.6SNR(i)-4<0 
round (0.6SNR(i) - 4) < 0.6SNR(i) - 4 < 7 
7 0.6SNR(i) > 7 



10 



In step 612, the voice activity decision is made in the following manner according 
to the current invention. If either £ 4 (0)-£„(0) > THRESH(Re gsNR (0)), °r £ 6 (1)-£„(1) > 
THRESH{Reg SNK ( 1 )), then the frame of speech is declared active. Otherwise, the frame of 
speech is declared inactive. The values of THRESH are defined in Table 2. 



Table 2: Threshold Factors as A function of the SNR Region 



15 



SNR Reeion 


THRESH 


0 


2.807 


. 1 


2.807 


2 


3.000 


3 


3.104 


4 


3.154 


5 


3.233 


6 


3.459 


7 


3.982 



20 



The signal energy estimates, E/i), are preferably updated using the following 
25 equation: 



£,(*')= £,(0-0.014499, / = o,l. 
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The noise energy estimates, E n (i) y are preferably updated using the following 
equation: 

4 0.0066 < 4 

- E n {\) = 1 23 23 < £„(/)+ 0.0066 , / = 0,1 

£*„(/)+ 0.0066 otherwise 



A. Hangover Frames 



5 When signal-to-noise ratios are low, "hangover" frames are preferably added to 

improve the quality of the reconstructed speech. If the three previous frames were 
classified as active, and the current frame is classified inactive, then the next M frames 
including the current frame are classified as active speech. The number of hangover 
frames, M, is preferably determined as a function ofSNR(0) as defined in Table 3 . 



Table 3: Hangover Frames as a Function of SNR(0) 



SNR(0) 


M 


0 


4 


1 


3 


2 


3 


3 


3 


4 


3 


5 


3 


6 


3 


7 


3 



20 V. Classification of Active Speech Frames 



Referring back to FIG. 3, in step 308, current frames which were classified as being 
active in step 304 are further classified according to properties exhibited by the speech 
signal s(n). In a preferred embodiment, active speech is classified as either voiced, 
unvoiced, or transient. The degree of periodicity exhibited by the active speech signal 
25 determines how it is classified. Voiced speech exhibits the highest degree of periodicity 
(quasi-periodic in nature). Unvoiced speech exhibits little or no periodicity. Transient 
speech exhibits degrees of periodicity between voiced and unvoiced. 
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However, the general framework described herein is not limited to the preferred 
classification scheme and the specific encoder/decoder modes described below. Active 
speech can be classified in alternative ways, and alternative encoder/decoder modes are 
available for coding. Those skilled in the art will recognize that many combinations of 
5 classifications and encoder/decoder modes are possible. Many such combinations can 
result in a reduced average bit rate according to the general framework described herein, 
i.e., classifying speech as inactive or active, further classifying active speech, and then 
coding the speech signal using encoder/decoder modes particularly suited to the speech 
falling within each classification. 
10 Although the active speech classifications are based on degree of periodicity, the 

classification decision is preferably not based on some direct measurement of periodicty. 
Rather, the classification decision is based on various parameters calculated in step 302, 
e.g., signal to noise ratios in the upper and lower bands and the NACFs. The preferred 
classification may be described by the following pseudo-code: 

1 5 if not(previousNA CF < 0. 5 and currentNA CF>0.6) 

if (currentN ACF < 0.75 and ZCR > 60) UNVOICED 
else if (previousN ACF < 0.5 and currentN ACF < 0.55 

and ZCR > 50) UNVOICED 
else if (currentN ACF < 0.4 and ZCR > 40) UNVOICED 
20 if (UNVOICED and currentSNR > 2idB 

and E L >aE H ) TRANSIENT 
if (previousN ACF < 0.5 and currentN ACF < 0.5 

and E<5e4 + N) UNVOICED 
if (VOICED and iow-bandSNR > high-bandSNR 
25 and previousN A CF < 0 . 8 and 

0.6 < currentN ACF < 0.75) TRANSIENT 



1.0, E>5e5 + N aol „ 
whereflr = 120.0, E<5e5 + N noae 

mi N na» is an estimate of the background noise. E pw is the previous frame's input energy. 
The method described by this pseudo code can be refined according to the specific 
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environment in which it is implemented. Those skilled in the art will recognize that the 
various thresholds given above are merely exemplary, and could require adjustment in 
practice depending upon the implementation. The method may also be refined by adding 
additional classification categories, such as dividing TRANSIENT 'into two categories: one 
5 for signals transitioning from high to low energy, and the other for signals transitioning 
from low to high energy. 

Those skilled in the art will recognize that other methods are available for 
distinguishing voiced, unvoiced, and transient active speech. Similarly, skilled artisans will 
recognize that other classification schemes for active speech are also possible. 

10 VI. Encoder/Decoder Mode Selection 

In step 310, an encoder/decoder mode is selected based on the classification of the 

mm.m. — w -« -v w , i wv«4-U.'U'ig %,\S t+ piViWU feU WlUUUUliilVlit, illOUCO Ul 

selected as follows: inactive frames and active unvoiced frames are coded using a NELP 
mode, active voiced frames are coded using a PPP mode, and active transient frames are 
15 coded using a CELP mode. Each of these encoder/decoder modes is described in detail in 
following sections. 

In an alternative embodiment, inactive frames are coded using a zero rate mode 
Skilled artisans will recognize that many alternative zero rate modes are available which 
require very low bit rates. The selection of a zero rate mode may be further refined by 

20 considering past mode selections. For example, if the previous frame was classified as 
active, this may preclude the selection of a zero rate mode for the current frame. Similarly, 
if the next frame is active, a zero rate mode may be precluded for the current frame. 
Another alternative is to preclude the selection of a zero rate mode for too many 
consecutive frames {e.g., 9 consecutive frames). Those skilled in the art will recognize that 

25 many other modifications might be made to the basic mode selection decision in order to 
refine its operation in certain environments. 

As described above, many other combinations of classifications and 
encoder/decoder modes might be alternatively used within this same framework. The 
following sections provide detailed descriptions of several encoder/decoder modes 

30 according to the present invention. The CELP mode is described first, followed by the PPP 
mode and the NELP mode. 
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Vn. Code Excited Linear Prediction (CELP) Coding Mode 

As described above, the CELP encoder/decodermode is employed when the current 
frame is classified as active transient speech. The CELP mode provides the most accurate 
signal reproduction (as compared to the other modes described herein) but at the highest bit 
5 rate. 

FIG. 7 depicts a CELP encoder mode 204 and a CELP decoder mode 206 in further 
detail. As shown in FIG. 7A, CELP encoder mode 204 includes a pitch encoding module 
702, an encoding codebook 704, and a filter update module 706. CELP encoder mode 204 
outputs an encoded speech signal, Sens (n), which preferably includes codebook parameters 
1 0 and pitch filter parameters, for transmission to CELP decoder mode 206. As shown in FIG. 
7B, CELP decoder mode 206 includes a decoding codebook module 708, a pitch filter 710, 
and an LPC synthesis filter 712. CELP decoder mode 206 receives the encoded speech 
signal and outputs synthesized speech signal s(h) . 



A. Pitch Encoding Module 

15 Pitch encoding module 702 receives the speech signal s(n) and the quantized 

residual from the previous frame, p/n) (described below). Based on this input, pitch 
encoding module 702 generates a target signal x(n) and a set of pitch filter parameters. In 
a preferred embodiment, these pitch filter parameters include an optimal pitch lag L* and 
an optimal pitch gain b*. These parameters are selected according to an "analysis-by- 

20 synthesis" method in which the encoding process selects the pitch filter parameters that 
minimize the weighted error between the input speech and the synthesized speech using 
those parameters. 

FIG. 8 depicts pitch encoding module 702 in greater detail. Pitch encoding module 
702 includes a perceptual weighting filter 802, adders 804 and 8 1 6, weighted LPC synthesis 
25 filters 806 and 808, a delay and gain 810, and a minimize sum of squares 812. 

Perceptual weighting filter 802 is used to weight the error between the original 
speech and the synthesized speech in a perceptually meaningful way. The perceptual 
weighting filter is of the form 
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W{z) = 



A(z) 



A{zly) 



where A(z) is the LPC prediction error filter, and y preferably equals 0.8. Weighted LPC 
analysis filter 806 receives the LPC coefficients calculated by initial parameter calculation 
module 202. Filter 806 outputs a Itr (n) t which is the zero input response given the LPC 
coefficients. Adder 804 sums a negative input a zir (n) and the filtered input signal to form 
5 target signal x(n). 

Delay and gain 810 outputs an estimated pitch filter output bpjn) for a given pitch 
lag L and pitch gain b. Delay and gain 810 receives the quantized residual samples from 
the previous frame,/? c (hj 5 and an estimate of future output of the pitch filter, given by p a (n)> 
and forms p(n) according to: 



10 which is then delayed by L samples and scaled by b to form bp L (n). Lp is the subframe 
length (preferably 40 samples). In a preferred embodiment, the pitch lag, L, is represented 
by 8 bits and can take on values 20.0, 20.5,21.0,21.5, ■» 126.0, 126.5, 127.0, 127.5. 

Weighted LPC analysis filter 808 filters bp L (n) using the current LPC coefficients 
resulting in by L (n). Adder 816 sums a negative input by L (n) with x(n) y the output of which 

15 is received by minimize sum of squares 812. Minimize sum of squares 812 selects the 
optimal L, denoted by and the optimal b y denoted by b* y as those values of L and b that 
minimize E pitch (L) according to: 





L p -\ L p -\ 

If £^(L)A I x(n)y L (n) and Eyy(L)A I , then the value of b which 




minimizes E ptteh (L) for a given value of L is 
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6* = 



for which 



where K is a constant that can be neglected. 

The optimal values of L and b (L* and b*) are found by first determining the value 
of L which minimizes E pi ,JL) and then computing b *. 

These pitch filter parameters are preferably calculated for each subframe and then 
quantized for efficient transmission. In a preferred embodiment, the transmission codes 
PLAGj and PGAINj for the f subframe are computed as 



PGAINy = 



g 

min{6*,2}- + 0.5 



-1 



PLAG,- = { 0 ' P GATN/ = -l 

[2L*, 0<PGAIN/<8 

PGAINj is then adjusted to - 1 ifPLAG; is set to 0. These transmission codes are transmitted 
to CELP decoder mode 206 as the pitch filter parameters, part of the encoded speech signal 
0 s.Jn). 

B. Encoding Codebook 

Encoding codebook 704 receives the target signal x(n) and determines a set of 
codebook excitation parameters which are used by CELP decoder mode 206, along with the 
pitch filter parameters, to reconstruct the quantized residual signal. 
5 Encoding codebook 704 first updates x(n) as follows. 

*(") = *(«) - y„ ir (»), 0 <, n < 40 
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where y pxir (n) is the output of the weighted LPC synthesis filter (with memories retained 
from the end of the previous subframe) to an input which is the zero-input-response of the 

pitch filter with parameters L * and b * (and memories resulting from the previous 

subframe's processing). 

5 A backfiltered target d = [d n } , 0 < n < 40 is created as d = H T x where 

7* 0 0 0 ...o 
_h 39 h 3% h 31 — h 0 _ 

is the impulse response matrix formed from the impulse response {/?„} and 
x = {x(w)},0 < n < 40 . Two more vectors ^ = and s are created as well. 



2 3 z"^, +n > 0<«<40 

i=0 

Etf, « = o 

1 1=0 



where 



10 Encoding codebook 704 initializes the values Exy* and Eyy* to zero and searches 

for the optimum excitation parameters, preferably with four values of N (0, 1, 2, 3), 
according to: 
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p = 


(^+{0,1,2,3 5 4})%5 


A = 


{Po>Po + 5,...,/' < 40} 


B = 


{a,/>i + 5,...,*'<40} 


De \k = 


2 A + 




{'o>A} = 


arg max< 






Den* 













ExyO= d h + d h 
EyyO= Eyy !aJx 

A = {P2>P 2 + 5 >-,i' < 40} 
B ={p 3 ,p 3 + 5,.. ., k' < 40} 
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i e Ak e B 
{S2,S 3 } 



Exyl 
Eyy\ 
A 

Den, 



arg max" 



• 1 ^ 



i€-4 Den ik 



Dew 



{p4,P 4 + 5,. .,'' <40} 



h - 


arg max' 
















Exyl = 


■- Exyl + \d It 


£yy2 = 


■- Den u 





Den, 



If Exyl 2 Eyy* > Exy* 1 Eyy2 { 



Exy* = Exy2 
Eyy* = Eyyl 

{ind p0 , ind plt ind p2 , ind p3t ind p4 ) = {1^ I Jt I 2 , I 3 , I 4 ) 
{sgn p0 , sgn pi , sgn p2t sgn p „ sgn p4 ) = {S^ S h S Jf S<) 



Encoding codebook 704 calculates the codebook gain G* as , and then 

Eyy* 



quantizes the set of excitation parameters as the following transmission codes for the /* 
subframe: 
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0< k < 5 



5 

0, sgn k = 1 

, OS k< 5 

1, sgn t = - ] 



min{log 2 (max{l,G*}),l 1.2636)— — — + 05 
L j 11.2636 



1 1.2636 



and the quantized gain G* is 2 CBGj 3i 

Lower bit rate embodiments of the CELP encoder/decoder mode may be realized 
by removing pitch encoding module 702 and only performing a codebook search to 
determine an index / and gain G for each of the four subframes. Those skilled in the art 
5 will recognize how the ideas described above might be extended to accomplish this lower 
bit rate embodiment. 

C. CELP Decoder 

CELP decoder mode 206 receives the encoded speech signal, preferably including 
codebook excitation parameters and pitch filter parameters, from CELP encoder mode 204, 
10 and based on this data outputs synthesized speech s(ri) . Decoding codebook module 708 

receives the codebook excitation parameters and generates the excitation signal cb(n) with 
a gain of G. The excitation signal cb(n) for the/* subframe contains mostly zeroes except 
for the five locations: 

I k =5CBIJIc + k, 0zk<5 
which correspondingly have impulses of value 

S t =\-2SlGNjk, 0zk<S 

15 all of which are scaled by the gain G which is computed to bel^ 1 ^ , to provide 
Gcb(n). 

Pitch filter 710 decodes the pitch filter parameters from the received transmission 
codes according to: 
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Z+= PLAQ/ 
2 

0, L* = 0 



^PGAIN;, 2**0 



Pitch filter 710 then filters Gcb(ri) } where the filter has a transfer function given by 

1 1 

In a preferred embodiment, CELP decoder mode 206 also adds an extra pitch 
filtering operation, a pitch prefilter (not shown), after pitch filter 71 0. The lag for the pitch 
prefilter is the same as that of pitch filter 710, whereas its gain is preferably half of the pitch 
5 gain up to a maximum of 0.5. 

LPC synthesis filter 712 receives the reconstructed quantized residual signal 

r (ji) and outputs the synthesized speech signal s(ri) . 



D. Filter Update Module 

Filter update module 706 synthesizes speech as described in the previous section 
10 in order to update filter memories. Filter update module 706 receives the codebook 
excitation parameters and the pitch filter parameters, generates an excitation signal cb(n), 
pitch filters Gcb(n), and then synthesizes s(n) f By performing this synthesis at the 

encoder, memories in the pitch filter and in the LPC synthesis filter are updated for use 
when processing the following subframe. 
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Vm. Prototype Pitch Period (PPP) Coding Mode 



Prototype pitch period (PPP) coding exploits the periodicity of a speech signal to 
achieve lower bit rates than may be obtained using CELP coding. In general, PPP coding 
involves extracting a representative period of the residual signal, referred to herein as the 
5 prototype residual, and then using that prototype to construct earlier pitch periods in the 
frame by interpolating between the prototype residual of the current frame and a similar 
pitch period from the previous frame (i.e., the prototype residual if the last frame was PPP). 
The effectiveness (in terms of lowered bit rate) of PPP coding depends, in part, on how 
closely the current and previous prototype residuals resemble the intervening pitch periods. 
10 For this reason, PPP coding is preferably applied to speech signals that exhibit relatively 
high degrees of periodicity (e.g. , voiced speech), referred to herein as quasi-periodic speech 
signals. 

FIG. 9 depicts a PPP encoder mode 204 and a PPP decoder mode 206 in further 
detail. PPP encoder mode 204 includes an extraction module 904, a rotational correlator 
15 906, an encoding codebook 908, and a filter update module 910. PPP encoder mode 204 . 
receives the residual signal r(n) and outputs an encoded speech signal s,Jn), which 
preferably includes codebook parameters and rotational parameters. PPP decoder mode 206 
. includes a codebook decoder 912, a rotator 914, an adder 916, a period interpolator 920, 
and a warping filter 918. 

20 FIG. 1 0 is a flowchart 1 OOO'depicting the steps of PPP coding, including encoding 

and decoding. These steps are discussed along with the various components of PPP 
encoder mode 204 and PPP decoder mode 206. 
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A. Extraction Module 

In step 1002, extraction module 904 extracts a prototype residual r/nj from the 
residual signal r(n). As described above in Section III.F., initial parameter calculation 
module 202 employs an LPC analysis filter to compute r(n) for each frame. In a preferred 
5 embodiment, the LPC coefficients in this filter are perceptually weighted as described in 
Section VILA. The length otr/n) is equal to the pitch lag L computed by initial parameter 
calculation module 202 during the last subframe in the current frame. 

FIG. 1 1 is a flowchart depicting step 1002 in greater detail. PPP extraction module 
904 preferably selects a pitch period as close to the end of the frame as possible, subject to 
10 certain restrictions discussed below. FIG. 12 depicts an example of a residual signal 
calculated based on quasi-periodic speech, including the current frame and the last 
subframe from the previous frame. 

Tn fifpn 1 1 00 a "nit-frw r^ni^T*" ir r4^+^-^:«^ J TM * JZ :__ i _ r> r- 

r - _ _ _ «^<w H -»- v& »w4«< w-awcwi'uu'ucci. nit out-acc icgiou UCUI1CS d set OI 

samples in the residual which cannot be endpoints of the prototype residual. The cut-free 
1 5 region ensures that high energy regions of the residual do not occur at the beginning or end 

of the prototype (which could cause discontinuities in the output were it allowed to happen). 

The absolute value of each of the final L samples of r(n) is calculated. The variable P s is 

set equal to the time index of the sample with the largest absolute value, referred to herein 

as the "pitch spike. " For example, if the pitch spike occurred in the last sample of the final 
20 L samples, P s = Z.-1. In a preferred embodiment, the minimum sample of the cut-free 

region, CF min> is set to be P s - 6 or P s - 0.25Z, whichever is smaller. The maximum of the 

cut-free region, CF mar , is set to be P s + 6 or P s + 0.25Z, whichever is larger. 

In step 1104, the prototype residual is selected by cutting L samples from the 

residual. The region chosen is as close as possible to the end of the frame, under the 
25 constraint that the endpoints of the region cannot be within the cut-free region. The L 

samples of the prototype residual are determined using the algorithm described in the 

following pseudo-code: 

if(CF mm <0){ 

for(/ = 0 to L + CF mi -\) r,(i) = r(;+160-Z,) 
30 for(; = CF mi „ to L-\) r p (i) = 60-2Z.) 

) 
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else if(CF mai <; L { 

for(; = 0 to CF mm -l) r p (0 = r('+160-Z,) 
for(/ = CF min to Z-l) r p (i) = r(/+l60-2L) 

} 

5 else { 

for(/ = 0 to Z,-l) r p (i) = r(/+160-Z,) 

} 



B. Rotational Correlator 



Referring back to FIG. 1 0, in step 1 004, rotational correlator 906 calculates a set of 
10 rotational parameters based on the current prototype residual, r p (n) f and the prototype 
residual from the previous frame, r pr Jn). These parameters describe how r pr Jn) can best 
be rotated and scaled for use as a predictor of r/nj. In a preferred embodiment, the set of 
rotational parameters includes an optimal rotation R* and an optimal gain b*. FIG. 13 is 
a flowchart depicting step 1 004 in greater detail. 
1 5 In step 1 302, the perceptually weighted target signal x(n) t is computed by circularly 

filtering the prototype pitch residual period r p (n). This is achieved as follows. A temporary 
signal tmp\(n) is created from r p (n) as 

tmpl(n)=[>' ) ■ L ^ n<2L 

which is filtered by the weighted LP C synthesis filter with zero memories to provide an 
20 output tmp2(n). In a preferred embodiment, the LPC coefficients used are the perceptually 
weighted coefficients corresponding to the last subframe in the current frame. The target 
signal x(n) is then given by 

x(n) = tmp2(n) + tmp2(n + 1), 0 <, n <L 



In step 1 304, the prototype residual from the previous frame, r pr€V (n) t is extracted 
25 from the previous frame's quantized formant residual (which is also in the pitch filter's 
memories). The previous prototype residual is preferably defined as the last L p values of 
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the previous frame's formant residual, whiere L p is equal to L if the previous frame was not 
a PPP frame, and is set to the previous pitch lag otherwise. 

In step 1 306, the length oir prev (n) is altered to be of the same length as x(n) so that 
correlations can be correctly computed. This technique for altering the length of a sampled 
5 signal is referred to herein as warping. The warped pitch excitation signal, rw prev (n) y may 
be described as 

mpjp) = r prw {n * TWF), 0 s n < L 
L p 

where TWF is the time warping factor — - . The sample values at non-integral points n * 

L 

7WFare preferably computed using a set of sine function tables. The sine sequence chosen 
10 is sinc(-3 - F : 4 - F) where F is the fractional part of n * TWF rounded to the nearest 

multiple of ^ . The beginning of this sequence is aligned with r prev ((N-3)%L p ) where AT is 

the integral part of n*TWF after being rounded to the nearest eighth. 

In step 1308, the warped pitch excitation signal rw prrv (n) is circularly filtered, 
resulting in y(n) t This operation is the same as that described above with respect to step 
15 1302, but applied to rw (n). 

In step 1310, the pitch rotation search range is computed by first calculating an 
expected rotation E ron 

Ere = L- round (Lfracy ^— £ / ) 

P 

where frac(x) gives the fractional part of x. If L < 80, the pitch rotation search range is 
20 defined to be i£ rot - 8, E rot -7.5, ... E rot + 7.5), and l£ rof - 16, E rot - 15, ... E rot + 1 5) where 
L*80. 

In step 1312, the rotational parameters, optimal rotation^ * and an optimal gain b *, 
arc calculated. The pitch rotation which results in the best prediction between x(n) zndyfrtj 
is chosen along with the corresponding gain b. These parameters are preferably chosen to 
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minimize the error signal e(n) = x(n)-y( n ). The optimal rotation R* and the optimal 



gain 



A* are those values of rotation/? and gain b which result in the maximum value of 



£ -' L-X 



^-g^ + J^i W0 *ndEyy = ±y (0y(i) for which the optimal gain 

i=0 



Exy R + 

b * " If^T" r ° tati0n ** F ° r fractional values of rotation, the value of Exy R 



is 



5 approximated by interpolating the values of Exy R computed at integer values of rotation. 
A simple four tap interplation filter is used. For example, 

Exy R = 0.54(Exy R . + Exy R%l ) - 0.04 * (Exy K .., + Exy R . +2 ) 
where R is a non-integral rotation (with precision of 0.5) and R' = IRJ. 

In a preferred embodiment, the rotational parameters are quantized for efficient 
10 transmission. The optimal gain b* is preferably quantized uniformly between 0.0625 and 



4.0 as 



PGAIN=max min( 



J b* -0.0625) 

63 +05 

U- 0.0625; 



,63),0 



where PGAIN is the transmission code and the quantized gain b* is given by 
lnn*« ( PGA1N (4 -0.0625)) 1 

] I 63 J, 0.0625 . The optimal rotation R* is quantized as the 

15 transmission code PROT, which is set to 2(R* - E, a + 8) if L < 80, and R* - E rol + 16 
where Li 80. 



C. Encoding Codebook 



Referring back to FIG. 10, instep 1006, encoding codebook 908 generates a set of 
codebook parameters based on the received target signal x(n). Encoding codebook 908 
20 seeks to find one or more codevectors which, when scaled, added, and filtered sum to a 
signal which approximates x(n). In a preferred embodiment, encoding codebook 908 is 
implemented as a multi-stage codebook, preferably three stages, where each stage produces 
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a scaled codevector. The set of codebook parameters therefore includes the indexes and 
gains corresponding to three codevectors. FIG. 14 is a flowchart depicting step 1006 in 
greater detail. 

In step 1402, before the codebook search is performed, the target signal x(n) is 
5 updated as 

x(n) = x(n) - b y((n - R *)%!), 0 in < L 
If in the above subtraction the rotation J?* is non-integral {i.e., has afraction of 0.5), 

then 

y{i - 0.5) = -0.0073O</ - 4) + y(i + 3)) + 0.03 22(X' - 3) + y(i + 2)) 
-0.1363(3/(i - 2) + y(i + 1)) + 0.6076(y(/ - 1) + y(i)) 

10 where i = n-lR*l 

T _ . _ ._ ■% A f\ A a. I 1.1 1 I „. ~ nnn A <*-«-n mnUtnlA fom rvnC A C C f\ J~f\ 1 Tl (7 

III SlGp IHUH, U1C tUUCUUUK V'aiac» mVpoi'UUOi»u-iiHO'Jiian^iw-x v & -»w>i«-. - — o 

to a preferred embodiment, the codebook is determined as 



c(/i) = 



1, * = 0 

0, 0<n<L 
CBP{n-L\ L<n<\2Z+L 



where CBP are the values of a stochastic or trained codebook. Those skilled in the art will 
15 recognize how these codebook values are generated. The codebook is partitioned into 
multiple regions, each of length L. The first region is a single pulse, and the remaining 
regions are made up of values from the stochastic or trained codebook. The number of 

regions N will be [128/1,1 

In step 1406, the multiple regions of the codebook are each circularly filtered to 
20 produce the filtered codebooks, y m (n), the concatenation of which is the signal y(n). For 
each region, the circular filtering is performed as described above with respect to step 1 3 02. 

In step 1408, the filtered codebook energy, Eyy(reg) y is computed for each region 
and stored; 



L-\ 



Eyy(reg) = £ y reg (i), 0 < reg < N 



i = 0 
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In step 1410, the codebook parameters (i.e., codevector index and gain) for each 
stage of the multi-stage codebook are computed. According to a preferred embodiment, let 
Regionfl) = reg, defined as the region in which sample / resides, or 



Region(I) = < 



0, 
1, 



0< / < L 
L<.I <2L 



2, 2L <, I < 3L 



5 and let Exy(I) be defined as 

i-i 



Exy(I)= Z*(0^, nW ((/ + I)%L) 



i=0 



The codebook parameters, /* and G*. for they* codebook stage are computed using 
the following pseudo-code. 

Exy*=0,Eyy*=0 
for(I= Otol 27) { 

compute E xy(I) 

if(Exy(I)jEyy* > Exy*(iy Eyy (Region (I))) { 
Exy * = Exy(I) 
Eyy*= Eyy(Region(l)) 
/*= / 

, } 



_ Exy * 
10 and G*= — — 
Eyy* 

According to a preferred embodiment, the codebook parameters are quantized for 
efficient transmission. The transmission code CBI/ (j=stage number - 0, 1 or 2) is 
preferably set to /* and the transmission codes CBG> and SIGN; are set by quantizing the 
gain G *. 



15 
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min{max{0, log 2 (\G *|)}, 1 1.25} ^ + 0.5 



CBGj = 
and the quantized gainG * is 

J 

^OJSCBGj, SIGN j^Q 



G * = j 2 01SCBGJ SIGNj = 0 



The target signal x(n) is then updated by subtracting the contribution of the 
5 codebook vector of the current stage 

x(n) = x(n)-G*y Region(I . ) ((n + J*)%L), 0 < n < L 

The above procedures starting from the pseudo-code are repeated to compute/*, G * 
and the corresponding transmission codes, for the second and third stages. 



D. Filter Update Module 



10 Referring back to FIG. 1 0, in step 1008, filter update module 910 updates the filters 

used by PPP encoder mode 204. Two alternative embodiments are presented for filter 
update module 910, as shown in FIGs. 15A and 16A. As shown in the first alternative 
embodiment in FIG. 15 A, filter update module 910 includes a decoding codebook 1502, 
a rotator 1 504, a warping filter 1 506, an adder 1 5 10, an alignment and interpolation module 

15 1508, an update pitch filter module 1512, and an LPC synthesis filter 1514. The second 
embodiment, as shown in FIG. 16A, includes a decoding codebook 1602, a rotator 1604, 
a warping filter 1606, an adder 1608, an update pitch filter module 1610, a circular LPC 
synthesis filter 1612, and an update LPC filter module 1614. FIGs. 17 and 18 are 
flowcharts depicting step 1008 in greater detail, according to the two embodiments, 

20 In step 1702 (and 1802, the first step of both embodiments), the current 

reconstructed prototype residual, r^Jn), L samples in length, is reconstructed from the 
codebook parameters and rotational parameters. In a preferred embodiment, rotator 1504 
(and 1 604) rotates a warped version of the previous prototype residual according to the 
following; 

25 r curr ((n + R+)°/oL) = brw pr „(n\ OZn < L 
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where r m is the current prototype to be created, r» pm is the warped (as described above 

o ■ K 
m Section VTII.A., with 7WF= ) version of the previous period obtained from the 

most recent L samples of the pitch filter memories, b the pitch gain and R the rotation 
obtained from packet transmission codes as 



». ^0.0625(^(^25), 00625 



63 

[PROT* 

R= ~T~ +jG "'~ 8 ' L<8 ° 

\PROT+E rot - 16, Z>80 



5 where E rot is the expected rotation computed as described above in Section VIII.B. 

Decoding codebook 1502 (and 1602) adds the contributions for each of the three 
codebook stages to r^n) as 

rcurriin — 0o/ oZ() = r _ /)%L) + f G > I < L, n = 0 

\GCBP(I-L + nX I>L y 0<n<L 

where I^CBIj and G is obtained from CBGj and SIGNj as described in the previous section, 
j being the stage number. 

10 At this point, the two alternative embodiments for filter update module 910 differ. 

Referring first to the embodiment of FIG. 15 A, in step 1704, alignment and interpolation 
module 1 508 fills in the remainder of the residual samples from the beginning of the current 
frame to the beginning of the current prototype residual (as shown in FIG. 12). Here, the 
alignment and interpolation are performed on the residual signal. However, these same 

15 operations can also be performed on speech signals, as described below. FIG. 19 is a 
flowchart describing step 1704 in further detail. 

In step 1902, it is determined whether the previous lag L p is a double or a half 
relative to the current lagZ. In a preferred embodiment, other multiples are considered too 
improbable, and are therefore not considered. If L p > 1.85L, L p is halved and only the first 

20 half of the previous period r pr Jn) is used. If L p < 0.54L, the current lag L is likely a double 
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and consequently L p is also doubled and the previous period r prev (n) is extended by 
repetition. 

In step 1904, r pr Jn) is warped to form rw pr Jn) as described above with respect to 

L 

step 1306, with TWF = , so that the lengths of both prototype residuals are now the 

L 

5 same. Note that this operation was performed in step 1702, as described above, by warping 
filter 1506. Those skilled in the art will recognize that step 1904 would be unnecessary if 
the output of warping filter 1506 were made available to alignment and interpolation 
module 1508. 

In step 1 906, the allowable range of alignment rotations is computed. The expected 
10 alignment rotation, E Ai is computed to be the same as E rot as described above in Section 
VIII.B. The alignment rotation search range is defined to be {E A - SA, E A - 5A + 0.5, E A - 
SA + 1, . . ., E A + 6A - 1.5, E A + 6A - 1), where 3A = max{6 1 0.15L}. 

In step 1908, the cross-correlations between the previous and current prototype 
periods for integer alignment rotations, i?, are computed as 

15 C( j 4) = X^(0'+^)%^) w p«v(0 

and the cross-correlations for non-integral rotations A are approximated by interpolating the 
values of the correlations at integral rotation: 

C(A) = 0.54(C(>T) + C04'+l)) - 0.04(C(^t / -l) + C(A'+2)) 



20 where A' = A-0.5. 

In step 1910, the value of^4 (over the range of allowable rotations) which results in 
the maximum value of C(A) is chosen as the optimal alignment, A * 

In step 1912, the average lag or pitch period for the intermediate samples, is 
computed in the following manner. A period number estimate, N pen is computed as 



25 



J A * (160- L)(L p + L)) 
N p „ =round^_ +— ^ j 
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with the average lag for the intermediate samples given by 

(160- L)L 



N ptr L-A* 



In step 1914, the remaining residual samples in the current frame are calculated 
according to the following interpolation between the previous and current prototype 

5 residuals: 



1- 



n 



rw prrv ((na)%L) 



160- L) 
n 

+ 160- L r ^ na * A *) % L)> 0<n<160-L 
r curr( n+ L- 160), 160-L<»<160 



I 



where a - The sample values at non-integral points n (equal to either na or na 

+A *) are computed using a set of sine function tables. The sine sequence chosen is sinc(-3 

-F: 4 - F) where F is the fractional part of n rounded to the nearest multiple of - . The 

8 

10 beginning of this sequence is aligned with r ^((NS^AL,) where N is the integral part of« 

after being rounded to the nearest eighth. 

Note that this operation is essentially the same as warping, as described above with 

respect to step 1306. Therefore, in an alternative embodiment, the interpolation of step 

1914 is computed using a warping filter. Those skilled in the art will recognize that 
15 economies might be realized by reusing a single warping filter for the various purposes 

described herein. 

Returning to FIG. 17, in step 1706, update pitch filter module 1512 copies values 
from the reconstructed residual r(n) to the pitch filter memories. Likewise, the memories 
of the pitch prefilter are also updated. 
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In step 1708, LPC synthesis filter 1514 filters the reconstructed residual r{n), 

which has the effect of updating the memories of the LPC synthesis filter. 

The second embodiment of filter update module 9 1 0, as shown in FIG. 1 6 A, is now 
described. As described above with respect to step 1702, in step 1802, the prototype 
5 residual is reconstructed from the codebook and rotational parameters, resulting in r^n). 

In step 1804, update pitch filter module 1610 updates the pitch filter memories by 
copying replicas of the L samples from r curr (n) J according to 

pitch_mem(i)=r curr {iL-{\2>\°/oL) + i)%L\ 0<i < 131 
or alternatively, 

10 pitch _mem(\3\- 1- /) = r curr (L- 1- 0< / < 131 

where 13 1 is preferably the pitch filter order for a maximum lag of 127.5. In a preferred 
embodiment, the memories of the pitch prefilter are identically replaced by replicas of the 
current period r^/n): 

pitch _prefilt _mem{i) = pitch _mem(i), 0 < / < 131 

15 In step 1806, r^Jn) is circularly filtered as described in Section VHI.B., resulting 

in s/n), preferably using perceptually weighted LPC coefficients. 

In step 1808, values from s/n) 9 preferably the last ten values (for a 10 th order LPC 
filter), are used to update the memories of the LPC synthesis filter. 

E. PPP Decoder 

20 Returning to FIGs. 9 and 10, in step 1010, PPP decoder mode 206 reconstructs the 

prototype residual r CU7r (n) based on the received codebook and rotational parameters. 
Decoding codebook 912, rotator 914, and warping filter 918 operate in the manner 
described in the previous section. Period interpolator 920 receives the reconstructed 
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prototype residual r^n) and the previous reconstructed prorotype residual r^Jn), 
interpolates the samples between the two prototypes, and outputs synthesized speech signal 
S(n) . Period interpolator 920 is described in the following section. 



F. Period Interpolator 

5 In step 1 0 1 2, period interpolator 920 receives r^Jn) and outputs synthesized speech 

signal s(n) Two alternative embodiments for period interpolator 920 are presented 
herein, as shown in FIGs. 15B and 16B. In the first alternative embodiment, FIG. 15B, 
period interpolator 920 includes an alignment and interpolation module 1516, an LPC 
synthesis filter 1518, and an update pitch filter module 1520. The second alternative 

10 embodiment, as shown in FIG. 16B, includes a circular LPC synthesis filter 1616, an 
alignment and interpolation module 1618, an update pitch filter module 1622, and an 
update LPC filter module 1620. FIGs. 20 and 21 are flowcharts depicting step 1012 in 
greater detail, according to the two embodiments. 

Referring to FIG. 15B, in step 2002, alignment and interpolation module 1516 

15 reconstructs the residual signal for the samples between the current residual prototype 
r^/n) and the previous residual prototype r p ,Jn), forming r(n) . Alignment and 

interpolation module 1516 operates in the manner described above with respect to step 
1704 (as shown in FIG. 19). 

In step 2004, update pitch filter module 1520 updates the pitch filter memories 
20 based on the reconstructed residual signal r(n) , as described above with respect to step 
1706. 

In step 2006, LPC synthesis filter 1518 synthesizes the output speech signal s(n) 
based on the reconstructed residual signal r («) . The LPC filter memories are 
automatically updated when this operation is performed. 

Referring now to FIGs. 16B and 21, in step 2 102, update pitch filter module 1622 
updates the pitch filter memories based on the reconstructed current residual prototype, 
r <*rr(n), as described above with respect to step 1804. 



25 
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In step 2104, circular LPC synthesis filter 1616 receives r^/n) and synthesizes a 
current speech prototype, s e (n) (which is L samples in length), as described above in Section 

VIII. B. 

In step 2106, update LPC filter module 1620 updates the LPC filter memories as 
5 described above with respect to step 1808. 

In step 2108, alignment and interpolation module 1618 reconstructs the speech 
samples between the previous prototype period and the current prototype period. The 
previous prototype residual, r pr Jn), is circularly filtered (in an LPC synthesis configuration) 
so that the interpolation may proceed in the speech domain. Alignment and interpolation 
10 module 1618 operates in the manner described above with respect to step 1704 (see Fig. 
19), except that the operations are performed on speech prototypes rather than residual 
prototypes. The result of the alignment and interpolation is the synthesized speech signal 
s(n). 

IX. Noise Excited Linear Prediction (NELP) Coding Mode 

15 Noise Excited Linear Prediction (NELP) coding models the speech signal as a 

pseudo-random noise sequence and thereby achieves lower bit rates than may be obtained 
using either CELP or PPP coding. NELP coding operates most effectively, in terms of 
signal reproduction, where the speech signal has little or no pitch structure, such as 
unvoiced speech or background noise. 
20 FIG. 22 depicts a NELP encoder mode 204 and a NELP decoder mode 206 in 

further detail. NELP encoder mode 204 includes an energy estimator 2202 and an encoding 
codebook 2204. NELP decoder mode 206 includes a decoding codebook 2206, a random 
number generator 2210, a multiplier 2212, and an LPC synthesis filter 2208. 

FIG. 23 is a flowchart 2300 depicting the steps of NELP coding, including encoding 
25 and decoding. These steps are discussed along with the various components of NELP 
encoder mode 204 and NELP decoder mode 206. 

In step 2302, energy estimator 2202 calculates the energy of the residual signal for 
each of the four subframes as 
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In step 2304, encoding codebook 2204 calculates a set of codebook parameters, 
forming encoded speech signal s.Jn). In a preferred embodiment, the set of codebook 
parameters includes a Single parameter, index 70. Index 70 is set equal to the value of j 

which minimizes 

5 

iiEsf t -SFEQU.(tf where 0,j<, 28 

The codebook vectors, SFEQ, are used to quantize the subframe energies Esf, and include 
a number of elements equal to the number of subframes within a frame (i.e., 4 in a preferred 
embodiment). These codebook vectors are preferably created according to standard 
10 techniques known to those skilled in the art for creating stochastic or trained codebooks. 

In step 2306, decoding codebook 2206 decodes the received codebook parameters. 
In a preferred embodiment, the set of subframe gains G, is decoded according to: 

G . = 2 sPEQcnw or 

CI = 90.2SFEQflO, i)+0.8log Gprev-2 / • 

^ z » (where the previous frame was coded using a 

lD zero-rate coding scheme) 

where 0 * i < 4 and Gprev is the codebook excitation gain corresponding to the last 
subframe of the previous frame. 

In step 2308, random number generator 2210 generates a unit variance random 
vector nz(n). This random vector is scaled by the appropriate gain Gi within each subframe 
20 in step 23 10, creating the excitation signal Gpz(n). 

In step 23 12, LPC synthesis filter 2208 filters the excitation signal Gpz(n) to form 
the output speech signal, s(ri) . 

In a preferred embodiment, a zero rate mode is also employed where the gain G,- and 
LPC parameters obtained from the most recent non-zero-rate NELP subframe are used for 
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each subframe in the current frame. Those skilled in the art will recognize that this zero 
rate mode can effectively be used where multiple NELP frames occur in succession. 

X. Conclusion 

While various embodiments of the present invention have been described above, it 
5 should be understood that they have been presented by way of example only, and not 
limitation. Thus, the breadth and scope of the present invention should not be limited by 
any of the above-described exemplary embodiments, but should be defined only in 
accordance with the following claims and their equivalents. 

The previous description of the preferred embodiments is provided to enable any 
.10 person skilled in the art to make or use the present invention. While the invention has been 
particularly shown and described with reference to preferred embodiments thereof, it will 
hpt understood -by those skilled in the sit that vsrious changes in form 3.nd details-m— " be 
made therein without departing from the spirit and scope of the invention. 
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WHAT IS CLAIMED IS: 

1 A method for the variable rate coding of a speech signal, comprising the steps of: 

(a) classifying the speech signal as either active or inactive; 

(b) classifying said active speech into one of a plurality of types of 
active speech; 

(c) selecting a coding mode based on whether the speech signalis active 
or inactive, and if active, based further on said type of active speech; 
and 

(d) encoding the speech signal according to said coding mode, forming 
an encoded speech signal. 

2. The method of claim 1 , further comprising the step of decoding said encoded speech 
signal according to said coding mode, forming a synthesized speech signal. 

3 . The method of claim 1 , wherein said coding mode comprises a CELP coding mode, 
a PPP coding mode, or a NELP coding mode. 

4. The method of claim 3, wherein said step of encoding encodes according to said 
coding mode at a predetermined bit rate associated with said coding mode. 

5 The method of claim 4, wherein said CELP coding mode is associated with a bit rate 
of 8500 bits per second, said PPP coding mode is associated with a bit rate of 3900 bits per 
second, and said NELP coding mode is associated with a bit rate of 1550 bits per second. 

6. The method of claim 3, wherein said coding mode further comprises a zero rate 
mode. 

7. The method of claim 1, wherein said plurality of types of active speech include 
voiced, unvoiced, and transient active speech. 
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8. The method of claim 7, wherein said step of selecting a coding mode comprises the 
steps of: 

(a) selecting a CELP mode if said speech is classified as active transient 
speech; 

(b) selecting a PPP mode if said speech is classified as active voiced speech; 
and 

(c) selecting a NELP mode if said speech is classified as inactive speech or 
active unvoiced speech. 

9. The method of claim 8, wherein said encoded speech signal comprises codebook 
parameters and pitch filter parameters if said CELP mode is selected, codebook parameters 
and rotational parameters if said PPP mode is selected, or codebook parameters if said 
NELP mode is selected. 

10. The method of claim 1 , wherein said step of classifying speech as active or inactive 
comprises a two energy band based thresholding scheme. 

1 1 . The method of claim 1, wherein said step of classifying speech as active or inactive 
comprises the step of classifying the next M frames as active if the previous N h0 frames 
were classified as active. 

12. The method of claim 1, further comprising the step of calculating initial parameters 
using a "look ahead." 



13. 



The method of claim 12, wherein said initial parameters comprise LPC coefficients. 
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1 4. The method of claim 1 , wherein said coding mode comprises a NELP coding mode, 
wherein the speech signal is represented by a residual signal generated by filtering the 
speech signal with a Linear Predictive Coding (LPC) analysis filter, and wherein said step 
of encoding comprises the steps of: 

(i) estimating the energy of the residual signal, and 

(ii) selecting a codevector from a first codebook, 
wherein said codevector approximates said 
estimated energy; 

and wherein said step of decoding comprises the steps of: 

(i) generating a random vector, 

(ii) retrieving said codevector from a second codebook, 

(iii) scaling said random vector based on said codevector, such that the 
energy of said scaled random vector approximates said estimated 
energy, and 

(iv) filtering said scaled random vector with a LPC synthesis filter, 
wherein said filtered scaled random vector forms said synthesized 
speech signal. 

15. The method of claim 14, wherein the speech signal is divided into frames, wherein 
each of said frames comprises two or more subframes, wherein said step of estimating the 
energy comprises the step of estimating the energy of the residual signal for each of said 
subframes, and wherein said codevector comprises a value approximating said estimated 
energy for each of said subframes. 

16. The method of claim 14, wherein said first codebook and said second codebook are 
stochastic codebooks. 

17. The method of claim 14, wherein said first codebook and said second codebook are 
trained codebooks. 



18. The method of claim 14, wherein said random vector comprises a unit variance 
random vector. 
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19. A variable rate coding system for coding a speech signal, comprising: 

classification means for classifying the speech signal as active or inactive, and if 

active, for classifying the active speech as one of a plurality of types of active speech; and 
a plurality of encoding means for encoding the speech signal as an encoded speech 

signal, wherein said encoding means are dynamically selected to encode the speech signal 

based on whether the speech signal is active or inactive, and if active, based further on said 

type of active speech. 

20. The system of claim 19, further comprising a plurality of decoding means for 
decoding said encoded speech signal. 

21 . The system of claim 1 9, wherein said plurality of encoding means includes a CELP 
encoding means, a PPP encoding means, and a NELP encoding means. 



' j — * PDT i> 
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22. The system of claim ZD, wnerem saw plurality 01 ueuuuwg 
decoding means, a PPP decoding means, and a NELP decoding means. 

23. The system of claim 21, wherein each of said encoding means encodes at a 
predetermined bit rate. 

24. The system of claim 23, wherein said CELP encoding means encodes at a rate of 
8500 bits per second, said PPP encoding means encodes at a rate of 3900 bits per second, 
and said NELP encoding means encodes at a rate of 1550 bits per second. 

25. The system of claim 21 , wherein said plurality of encoding means further includes 
a zero rate encoding means, and wherein said plurality of decoding means further includes 
a zero rate decoding means. 



26. The system of claim 19, wherein said plurality of types of active speech 
voiced, unvoiced, and transient active speech. 
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27. 



The system of claim 26, wherein said CELP encoder is selected if said speech is 
classified as active transient speech, wherein said PPP encoder is selected if said speech is 
classified as active voiced speech, and wherein said NELP encoder is selected if said speech 
is classified as inactive speech or active unvoiced speech. 

28. The system of claim 27, wherein said encoded speech signal comprises codebook 
parameters and pitch filter parameters if said CELP encoder is selected, codebook 
parameters and rotational parameters if said PPP encoder is selected, or codebook 
parameters if said NELP encoder is selected. 

29. The system of claim 1 9, wherein said classification means classifies speech as active 
or inactive based on a two energy band thresholding scheme. 

30. The system of claim 19, wherein said classification means classifies the next M 
frames as active if the previous N ho frames were classified as active. 

31. The system of claim 1 9, wherein the speech signal is represented by a residual signal 
generated by filtering the speech signal with a Linear Predictive Coding (LPC) analysis 
filter, and wherein said plurality of encoding means includes a NELP encoding means 
comprising: 

energy estimator means for calculating an estimate of the energy of the residual 
signal, and 

encoding codebook means for selecting a codevector from a first codebook, wherein 
said codevector approximates said estimated energy; 

and wherein said plurality of decoding means includes a NELP decoding means 
comprising: 

random number generator means for generating a random vector, 

decoding codebook means for retrieving said codevector from a second codebook, 

multiply means for scaling said random vector based on said codevector, such that 

the energy of said scaled random vector approximates said estimate, and 

means for filtering said scaled random vector with an LPC synthesis filter, wherein 

said filtered scaled random vector forms said synthesized speech signal. 
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32. The system of claim 19, wherein the speech signal is divided into frames, wherein 
each of said frames comprises two or more subframes, wherein said energy estimator means 
calculates an estimate of the energy of the residual signal for each of said subframes, and 
wherein said codevector comprises a value approximating said subframe estimate for each 
of said subframes. 

33. The system of claim 19, wherein said first codebook and said second codebook are 
stochastic codebooks. 

34. The system of claim 19, wherein said first codebook and said second codebook are 
trained codebooks. 

35. The system of claim 19, wherein said random vector comprises a unit variance 

ranHnm vpr.tnr 
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